## HDL Verifier™ Getting Started Guide

R2012a

# MATLAB® SIMULINK®



#### **How to Contact MathWorks**



(a)

www.mathworks.comWebcomp.soft-sys.matlabNewsgroupwww.mathworks.com/contact\_TS.htmlTechnical Support

suggest@mathworks.com bugs@mathworks.com doc@mathworks.com service@mathworks.com info@mathworks.com Product enhancement suggestions Bug reports Documentation error reports Order status, license renewals, passcodes Sales, pricing, and general information



508-647-7001 (Fax)

508-647-7000 (Phone)

The MathWorks, Inc. 3 Apple Hill Drive Natick, MA 01760-2098

For contact information about worldwide offices, see the MathWorks Web site.

HDL Verifier<sup>™</sup> Getting Started Guide

© COPYRIGHT 2003–2012 by The MathWorks, Inc.

The software described in this document is furnished under a license agreement. The software may be used or copied only under the terms of the license agreement. No part of this manual may be photocopied or reproduced in any form without prior written consent from The MathWorks, Inc.

FEDERAL ACQUISITION: This provision applies to all acquisitions of the Program and Documentation by, for, or through the federal government of the United States. By accepting delivery of the Program or Documentation, the government hereby agrees that this software or documentation qualifies as commercial computer software or commercial computer software documentation as such terms are used or defined in FAR 12.212, DFARS Part 227.72, and DFARS 252.227-7014. Accordingly, the terms and conditions of this Agreement and only those rights specified in this Agreement, shall pertain to and govern the use, modification, reproduction, release, performance, display, and disclosure of the Program and Documentation by the federal government (or other entity acquiring for or through the federal government) and shall supersede any conflicting contractual terms or conditions. If this License fails to meet the government's needs or is inconsistent in any respect with federal procurement law, the government agrees to return the Program and Documentation, unused, to The MathWorks, Inc.

#### Trademarks

MATLAB and Simulink are registered trademarks of The MathWorks, Inc. See www.mathworks.com/trademarks for a list of additional trademarks. Other product or brand names may be trademarks or registered trademarks of their respective holders.

#### Patents

MathWorks products are protected by one or more U.S. patents. Please see www.mathworks.com/patents for more information.

#### **Revision History**

August 2003 February 2004 June 2004 October 2004 December 2004 March 2005 September 2005 March 2006 September 2006 March 2007 September 2007 March 2008 October 2008 March 2009 September 2009 March 2010 September 2010 April 2011 September 2011 March 2012

Online only New for Version 1 (Release 13SP1) Updated for Version 1.1 (Release 13SP1) Updated for Version 1.1.1 (Release 14) Updated for Version 1.2 (Release 14SP1) Updated for Version 1.3 (Release 14SP1+) Updated for Version 1.3.1 (Release 14SP2) Updated for Version 1.4 (Release 14SP3) Updated for Version 2.0 (Release 2006a) Updated for Version 2.1 (Release 2006b) Updated for Version 2.2 (Release 2007a) Updated for Version 2.3 (Release 2007b) Updated for Version 2.4 (Release 2008a) Updated for Version 2.5 (Release 2008b) Updated for Version 2.6 (Release 2009a) Updated for Version 3.0 (Release 2009b) Updated for Version 3.1 (Release 2010a) Updated for Version 3.2 (Release 2010b) Updated for Version 3.3 (Release 2011a) Updated for Version 3.4 (Release 2011b) Updated for Version 4.0 (Release 2012a)

## Contents

## Introduction

| Product Description                                                                             | 1-2<br>1-2 |
|-------------------------------------------------------------------------------------------------|------------|
| HDL Cosimulation                                                                                | 1-3        |
| HDL Simulator                                                                                   | 1-3        |
| Communications for HDL Cosimulation                                                             | 1-8        |
| Hardware Description Language (HDL) Support<br>HDL Cosimulation Workflows Described in the User | 1-8        |
| Guide                                                                                           | 1-9        |
| FPGA Development                                                                                | 1-10       |
| FPGA Development with HDL Verifier                                                              | 1-10       |
| FPGA-in-the-Loop Simulation                                                                     | 1-10       |
| FPGA Automation with Filter Design HDL Coder                                                    | 1-11       |
| TLM Component Generation                                                                        | 1-12       |
| Development                                                                                     | 1-12       |
| Typical Users and Applications                                                                  | 1-13       |

1

2

## Installation

| Installing the HDL Verifier Software    | 2-2 |
|-----------------------------------------|-----|
| Installing Related Application Software | 2-3 |

| - |   |
|---|---|
| - | 6 |
| - | • |

| What You Need to Know                         | 3-2 |
|-----------------------------------------------|-----|
| For Cosimulating with HDL Simulators          | 3-2 |
| For FPGA-in-the-Loop Simulation               | 3-2 |
| For FPGA Automation                           | 3-3 |
| For Generating OSCI-Compatible TLM Components | 3-3 |
| Additional Useful Experience                  | 3-3 |
| Product Limitations                           | 3-3 |
| Required Products                             | 3-4 |
| Supported EDA Tools                           | 3-4 |
| System Requirements                           | 3-7 |
| Product Feature and Platform Support          | 3-7 |
| Optional Application Software                 | 3-9 |

## Getting Help

| 4 |
|---|
|---|

| Information Overview                        | 4-2               |
|---------------------------------------------|-------------------|
| Online Help                                 | 4-3               |
| Using "What's This?" Context-Sensitive Help | 4-5               |
| Demos and Tutorials<br>Demos<br>Tutorials   | 4-7<br>4-7<br>4-7 |

## 5

| Generate HDL Cosimulation Interfaces from Existing |        |
|----------------------------------------------------|--------|
| HDL Code                                           | 5-2    |
| Create a MATLAB Function From Existing HDL Code    | 5-2    |
| Create a MATLAB System Object From Existing HDL    |        |
| Code                                               | 5-9    |
| Create an HDL Cosimulation Block From Existing HDL |        |
| Code                                               | 5-10   |
| Perform Cosimulation                               | 5 - 21 |
|                                                    |        |

#### Import HDL Code For FPGA-in-the-Loop

| Verification                                       | 5 - 24 |
|----------------------------------------------------|--------|
| Preparing to Use the FPGA-in-the-Loop (FIL) Wizard | 5-24   |
| Running the FIL Wizard                             | 5 - 24 |
| Performing FIL Simulation                          | 5-29   |

## Index

# Introduction

- "Product Description" on page 1-2
- "HDL Cosimulation" on page 1-3
- "FPGA Development" on page 1-10
- "TLM Component Generation" on page 1-12

## **Product Description**

## Verify VHDL® and Verilog® using HDL simulators and FPGA-in-the-loop test benches

HDL Verifier<sup>™</sup> automates Verilog and VHDL design verification using HDL simulators and FPGA hardware-in-the-loop. It provides interfaces that link MATLAB<sup>®</sup> and Simulink<sup>®</sup> with Cadence Incisive<sup>®</sup>, Mentor Graphics<sup>®</sup> ModelSim<sup>®</sup>, and Mentor Graphics Questa<sup>®</sup> HDL simulators. It also supports FPGA-in-the-loop verification with Xilinx<sup>®</sup> and Altera<sup>®</sup> FPGA boards.

HDL Verifier automates verification by using MATLAB or Simulink to stimulate your HDL code and analyze its response. This approach eliminates the need to author standalone Verilog or VHDL test benches.

## **Key Features**

- Cosimulation support for Cadence Incisive and for Mentor Graphics ModelSim and Questa
- FPGA-in-the-loop verification using Xilinx and Altera FPGA boards
- MATLAB functions and Simulink blocks
- Generation of IEEE 1666 SystemC TLM 2.0 compatible transaction-level models
- Interactive or batch-mode cosimulation and debugging
- Single-machine, multiple-machine, and cross-network cosimulation

## **HDL Cosimulation**

#### In this section...

"HDL Cosimulation with MATLAB or Simulink and the HDL Simulator" on page 1-3

"Communications for HDL Cosimulation" on page 1-8

"Hardware Description Language (HDL) Support" on page 1-8

"HDL Cosimulation Workflows Described in the User Guide" on page 1-9

## HDL Cosimulation with MATLAB or Simulink and the HDL Simulator

HDL Verifier functions as a cosimulation interface that provides a bidirectional link between MATLAB and Simulink and HDL simulators from Mentor Graphics and Cadence<sup>®</sup>, enabling verification of VHDL, Verilog, and mixed-language implementations. This software enables interactive and batch-mode cosimulation on a single computer, across heterogeneous platforms, or across a network.

The HDL Verifier software consists of MATLAB functions, a MATLAB System object, and a library of Simulink blocks, all of which establish communication links between the HDL simulator and MATLAB or Simulink.

HDL Verifier software streamlines FPGA and ASIC development by integrating tools available for these processes:

1 Developing specifications for hardware design reference models

2 Implementing a hardware design in HDL based on a reference model

**3** Verifying the design against the reference design

The following figure shows how the HDL simulator and MathWorks<sup>®</sup> products fit into this hardware design scenario.



As the figure shows, HDL Verifier software connects tools that traditionally have been used discretely to perform specific steps in the design process. By connecting these tools, the link simplifies verification by allowing you to cosimulate the implementation and original specification directly. This cosimulation results in significant time savings and the elimination of errors inherent to manual comparison and inspection.

In addition to the preceding design scenario, HDL Verifier software enables you to work with tools in the following ways:

- Use MATLAB or Simulink to create test signals and software test benches for HDL code
- Use MATLAB or Simulink to provide a behavioral model for an HDL simulation
- Use MATLAB analysis and visualization capabilities for real-time insight into an HDL implementation
- Use Simulink to translate legacy HDL descriptions into system-level views

**Note** You can cosimulate a module using SystemVerilog, SystemC or both with MATLAB or Simulink using the HDL Verifier software. Write simple wrappers around the SystemC and make sure that the SystemVerilog cosimulation connections are to ports or signals of data types supported by the link cosimulation interface.

More discussion on how cosimulation works can be found in the following sections:

- "Linking with MATLAB and the HDL Simulator" on page 1-5
- "Linking with Simulink and the HDL Simulator" on page 1-6
- "The HDL Cosimulation Wizard" on page 1-8

#### Linking with MATLAB and the HDL Simulator

When linked with MATLAB, the HDL simulator functions as the client, as the following figure shows.



In this scenario, a MATLAB server function waits for service requests that it receives from an HDL simulator session. After receiving a request, the server establishes a communication link and invokes a specified MATLAB function that computes data for, verifies, or visualizes the HDL module (coded in VHDL or Verilog) that is under simulation in the HDL simulator.

After the server is running, you can start and configure the HDL simulator or use with MATLAB with the supplied HDL Verifier function:

- nclaunch (Incisive)
- vsim (ModelSim)

The following figure shows how a MATLAB test bench function wraps around and communicates with the HDL simulator during a test bench simulation session.



The following figure shows how a MATLAB component function is wrapped around by and communicates with the HDL simulator during a component simulation session.



When you begin a specific test bench or component session, you specify parameters that identify the following information:

- The mode and, if applicable, TCP/IP data for connecting to a MATLAB server
- The MATLAB function that is associated with and executes on behalf of the HDL instance
- Timing specifications and other control data that specifies when the module's MATLAB function is to be called

#### Linking with Simulink and the HDL Simulator

When linked with Simulink, the HDL simulator functions as the server, as shown in the following figure.



In this case, the HDL simulator responds to simulation requests it receives from cosimulation blocks in a Simulink model. You begin a cosimulation session from Simulink. After a session is started, you can use Simulink and the HDL simulator to monitor simulation progress and results. For example, you might add signals to an HDL simulator Wave window to monitor simulation timing diagrams.

Using the Block Parameters dialog box for an HDL Cosimulation block, you can configure the following:

- Block input and output ports that correspond to signals (including internal signals) of an HDL module. You can specify sample times and fixed-point data types for individual block output ports if desired.
- Type of communication and communication settings used for exchanging data between the simulation tools.
- Rising-edge or falling-edge clocks to apply to your module. You can individually specify the period of each clock.
- Tcl commands to run before and after the simulation.

HDL Verifier software equips the HDL simulator with a set of customized functions. For ModelSim, when you use the function vsimulink, you execute the HDL simulator with an instance of an HDL module for cosimulation with Simulink. After the module is loaded, you can start the cosimulation session from Simulink. Incisive users can perform the same operations with the function hdlsimulink.

HDL Verifier software also includes a block for generating value change dump (VCD) files. You can use VCD files generated with this block to perform the following tasks:

• View Simulink simulation waveforms in your HDL simulation environment

- Compare results of multiple simulation runs, using the same or different simulation environments
- Use as input to post-simulation analysis tools

#### The HDL Cosimulation Wizard

HDL Verifier contains the Cosimulation Wizard feature, which uses existing HDL code to create a customized MATLAB function (test bench or component), MATLAB Systemm object, or Simulink HDL Cosimulation block. For more information, see "HDL Cosimulation Wizard".

### **Communications for HDL Cosimulation**

The mode of communication that you use for a link between the HDL simulator and MATLAB or Simulink depends on whether your application runs in a local, single-system configuration or in a network configuration. If these products and MathWorks products can run locally on the same system and your application requires only one communication channel, you have the option of choosing between shared memory and TCP/IP socket communication. Shared memory communication provides optimal performance and is the default mode of communication.

TCP/IP socket mode is more versatile. You can use it for single-system and network configurations. This option offers the greatest scalability. For more on TCP/IP socket communication, see "Choosing TCP/IP Socket Ports".

### Hardware Description Language (HDL) Support

All HDL Verifier MATLAB functions and the HDL Cosimulation block offer the same language-transparent feature set for both Verilog and VHDL models.

HDL Verifier software also supports mixed-language HDL models (models with both Verilog and VHDL components), allowing you to cosimulate VHDL and Verilog signals simultaneously. Both MATLAB and Simulink software can access components in different languages at any level.

## HDL Cosimulation Workflows Described in the User Guide

The HDL Verifier User Guide provides instruction for using the verification software with supported HDL simulators for the following workflows:

- Simulating an HDL Component in a MATLAB Test Bench Environment
- Replacing an HDL Component with a MATLAB Component Function
- Simulating an HDL Component in a Simulink Test Bench Environment
- Replacing an HDL Component with a Simulink Algorithm
- Recording Simulink Signal State Transitions for Post-Processing

## **FPGA** Development

#### In this section ...

"FPGA Development with HDL Verifier" on page 1-10

"FPGA-in-the-Loop Simulation" on page 1-10

"FPGA Automation with Filter Design HDL Coder" on page 1-11

## **FPGA Development with HDL Verifier**

HDL Verifier works with Simulink and HDL Coder<sup>™</sup> or MATLAB and Filter Design HDL Coder<sup>™</sup> and the supported FPGA development environment to prepare your automatically generated HDL Code for implementation in an FPGA. HDL Verifier creates and manages your Xilinx ISE project and integrates a clock module with your design in an automatically generated top level module.

#### The FIL Wizard

HDL Verifier contains the FIL Wizard feature, which uses existing HDL code to create a customized FPGA implementation. For more information, see "Generating a FIL Block Using the FIL Wizard".

## **FPGA-in-the-Loop Simulation**

FPGA-in-the-Loop simulation allows you to run a Simulink simulation with an FPGA board strictly synchronized with Simulink. This lets you get real world data into your design while accelerating your simulation with the speed of an FPGA.

You can generate a FIL programming file in one of the following ways:

- Use the HDL Verifier FIL Wizard.
- Use the HDL Coder Workflow Advisor (see HDL Coder for instruction).

The FIL Wizard uses any synthesizable HDL code including code automatically generated from Simulink models by HDL Coder software. When you use FIL in the Workflow Advisor, HDL Coder uses the loaded design to create the HDL code. Either way, this HDL code is then augmented by customized code for FIL communication with your design and assembled into an FPGA project. The applicable downstream tools are used to process that project to create a programming file that is automatically downloaded to the FPGA device on a development board for verification. See HDL Verifier product page for a list of currently supported devices and boards.

HDL Verifier supports the use of a FIL block in a model reference block.

## FPGA Automation with Filter Design HDL Coder

Create, update, and manage FPGA projects with Xilinx ISE.HDL Verifier provides a Project Generator for generating HDL code from filter code using Filter Design HDL Coder.

HDL Verifier packages these files as a complete FPGA development environment project for use with Xilinx ISE.

With the interface, you can do the following:

- Take code generation process one step further and package up the generated code so you can use it with Xilinx tools (most of project info provided by HDL Verifier for project creation).
- Make changes to project info: automatically update generated code, add Simulink files to existing project, automatically manage generated files in associated project.
- Get settings from existing project and save these settings with the model.

#### FPGA Automation Workflows Described in the User Guide

The HDL Verifier User Guide provides instruction for using the verification software with supported FPGA development environments for the following workflows:

- Creating a new FPGA project
- Adding generated files to an existing FPGA project
- Generating Tcl scripts for project generation

See "FPGA Automation with Filter Design HDL Coder".

## **TLM Component Generation**

#### In this section...

"Generating TLM Components for Use with Virtual Platform Development" on page 1-12

"Typical Users and Applications" on page 1-13

## Generating TLM Components for Use with Virtual Platform Development

HDL Verifier lets you create a SystemC Transaction Level Model (TLM) that can be executed in any OSCI-compatible TLM 2.0 environment, including a commercial virtual platform.

When used with virtual platforms, HDL Verifier joins two different modeling environments: Simulink for high-level algorithm development and virtual platforms for system architectural modeling. The Simulink modeling typically dispenses with implementation details of the hardware system such as processor and operating system, system initialization, memory subsystems, device configuration and control, and the particular hardware protocols for transferring data both internally and externally.

The virtual platform is a simulation environment that is concerned about the hardware details: it has components that map to hardware devices such as processors, memories, and peripherals, and a means to model the hardware interconnect between them.

Although many goals could be met with a virtual platform model, the ideal scenario for virtual platforms is to allow for software development—both high level application software and low-level device driver software—by having fairly abstract models for the hardware interconnect that allow the virtual platform to run at near real-time speeds, as demonstrated in the following diagram.



The functional model provides a sort of halfway point between the speed you can achieve with abstraction and the accuracy you get with implementation.

## **Typical Users and Applications**

Using HDL Verifier and Simulink, you can create a TLM-2.0-compliant SystemC Transaction Level Model (TLM) that can be executed in any OSCI-compatible TLM 2.0 environment, including a commercial virtual platform.

Typical users and applications include:

- System-level engineers designing electronic system models that include architectural characteristics
- Software developers who want to incorporate an algorithm into a virtual platform without using an instruction set simulator (ISS).
- Hardware functional verification engineers. In this case, the algorithm represents a piece of hardware going into a chip.

# Installation

- "Installing the HDL Verifier Software" on page 2-2
- "Installing Related Application Software" on page 2-3

## Installing the HDL Verifier Software

For details on how to install the HDL Verifier software, see the MATLAB installation instructions.

## **Installing Related Application Software**

Based on your configuration decisions and the software required for your HDL Verifier application, identify software you need to install and where you need to install it. For example, if you need to run multiple instances of the link MATLAB server on different machines, you need to install MATLAB and any applicable toolbox software on multiple systems. Each instance of MATLAB can run only one instance of the server.

For details on how to install the HDL simulator, see the installation instructions for that product. For information on installing and activating MathWorks products, see the MATLAB installation and activation instructions.

# Product Requirements

- "What You Need to Know" on page 3-2
- "Required Products" on page 3-4

## What You Need to Know

The documentation provided with the HDL Verifier software assumes users have a moderate level of prerequisite knowledge in the following subject areas.

#### In this section...

"For Cosimulating with HDL Simulators" on page 3-2

"For FPGA-in-the-Loop Simulation" on page 3-2

"For FPGA Automation" on page 3-3

"For Generating OSCI-Compatible TLM Components" on page 3-3

"Additional Useful Experience" on page 3-3

"Product Limitations" on page 3-3

## For Cosimulating with HDL Simulators

- Hardware design and system integration
- VHDL and/or Verilog
- Cadence Incisive or Mentor Graphics ModelSim simulators
- MATLAB
- Experience with Simulink and Simulink Fixed Point<sup>™</sup> software is required for applying the Simulink component of the product
- Experience with Fixed-Point Toolbox<sup>™</sup> software required for working with MATLAB System objects

## For FPGA-in-the-Loop Simulation

- FPGA design and implementation
- VHDL and/or Verilog
- Simulink and Simulink Fixed Point software

Some familiarity with Xilinx ISE or Altera Quartus II may be helpful (see supported versions in "Required Products" on page 3-4).

## **For FPGA Automation**

- FPGA design and implementation
- VHDL and/or Verilog
- Filter Design HDL Coder software

Some familiarity with Xilinx ISE may be helpful.

## For Generating OSCI-Compatible TLM Components

- Simulink
- Embedded Coder<sup>™</sup> (some knowledge helpful)
- TLM 2.0
- System C 2.2 (compiling, linking, and executing)

## **Additional Useful Experience**

Depending on your application, experience with the following MATLAB toolboxes and Simulink blocksets might also be useful:

- Signal Processing Toolbox<sup>™</sup>
- Communications System Toolbox<sup>™</sup>
- DSP System Toolbox<sup>™</sup>
- Computer Vision System Toolbox<sup>™</sup>
- Simulink Fixed Point
- Embedded Coder

## **Product Limitations**

Compatibility with Simulink Code Generation:

- HDL Coder: The HDL Verifier HDL Cosimulation block does participate in code generation with HDL Coder.
- Simulink Coder™: The HDL Verifier HDL Cosimulation block does not participate in code generation with Simulink Coder for C code generation.

## **Required Products**

#### In this section ...

"Supported EDA Tools" on page 3-4 "System Requirements" on page 3-7 "Product Feature and Platform Support" on page 3-7 "Optional Application Software" on page 3-9

## **Supported EDA Tools**

- "Cosimulation Requirements" on page 3-4
- "FPGA Verification Requirements" on page 3-5

#### **Cosimulation Requirements**

- "Cadence Incisive Usage Requirements" on page 3-4
- "Mentor Graphics Questa and ModelSim Usage Requirements" on page 3-5

**Cadence Incisive Usage Requirements.** MATLAB and Simulink support Cadence verification tools using HDL Verifier.

Use one of these recommended versions, which have been fully tested against the current release:

- IES 10.2-s040
- IES 9.2-s014
- IUS 8.2-s009

The HDL Verifier shared libraries (liblfihdls\*.so, liblfihdlc\*.so) are built using the gcc included in the Cadence Incisive simulator platform distribution. Before you link your own applications into the HDL simulator, first try building against this gcc. See the HDL simulator documentation for more details about how to build and link your own applications.

#### Mentor Graphics Questa and ModelSim Usage Requirements.

MATLAB and Simulink support Mentor Graphics verification tools using HDL Verifier.

Use one of the following recommended versions. Each version has been fully tested against the current release:

- ModelSim SE 10.0c, 6.6d, 6.5f
- ModelSim PE 10.0c, 6.6d, 6.5f
- ModelSim DE 10.0c
- Questa 10.0a

The Linux<sup>®</sup> platform requires that HDL Verifier software run gcc c++ libraries (4.1 or later). You should install a recent version of the gcc c++ library on your computer. To determine which libraries are installed on your computer, type the command:

gcc -v

#### **FPGA Verification Requirements**

- "Xilinx ISE Usage Requirements" on page 3-5
- "Altera Quartus II Usage Requirements" on page 3-6
- "Supported FPGA Devices for FIL Simulation" on page 3-6
- "Supported FPGA Device Families for Clock Module Generation" on page 3-6

Xilinx ISE Usage Requirements. MATLAB and Simulink support Xilinx design tools using HDL Verifier.

- FPGA-in-the-Loop and FPGA Automation are tested with Xilinx ISE 13.1.
- ISE 11.1 or newer is recommended
- Additional requirements for clock module generation using FPGA Automation:

- 12.1 or later: Windows<sup>®</sup> only
- 11.4: Windows 32-bit only
- Consult Xilinx user documentation for compatibility of ISE tools with various Linux distributions.

**Altera Quartus II Usage Requirements.** MATLAB and Simulink support Altera design tools using HDL Verifier.

FPGA-in-the-Loop is tested with Altera Quartus II 11.0.

**Supported FPGA Devices for FIL Simulation.** HDL Verifier supports FIL simulation on the devices shown in the following table.

| Device<br>Family | Board                                                                                                                                                 |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Spartan-6        | Spartan-6 SP605<br>Spartan-6 SP601<br>XUP Atlys Spartan-6                                                                                             |
| Virtex-6         | Virtex-6 ML605                                                                                                                                        |
| Virtex-5         | Virtex-5 ML505<br>Virtex-5 ML506<br>Virtex-5 ML507<br>Virtex-5 XUPV5–LX110T                                                                           |
| Virtex-4         | Virtex-4 ML401<br>Virtex-4 ML402<br>Virtex-4 ML403                                                                                                    |
| Altera           | Arria II GX FPGA development kit<br>Cyclone III FPGA development kit<br>Cyclone IV GX FPGA development kit<br>DE2-115 development and education board |

**Supported FPGA Device Families for Clock Module Generation.** For project generation with Filter Design HDL Coder, see Xilinx documentation for a full list of supported FPGA families in ISE.

3-6

With the current release, clock module generation is supported for the following device families:

- Spartan-3
- Spartan-3A and Spartan-3AN
- Spartan-3A DSP
- Spartan-3E
- Spartan-6
- Virtex-4
- Virtex-5

### **System Requirements**

Visit the HDL Verifier Requirements page for general system requirements and product version availability.

## **Product Feature and Platform Support**

| Product<br>Feature                                        | Required<br>Products                                                | Recommended<br>Products                                    | Supported<br>Platforms                             |
|-----------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------|
| MATLAB and<br>HDL simulator<br>cosimulation<br>(function) | MATLAB                                                              | Fixed-Point<br>Toolbox, Signal<br>Processing<br>Toolbox    | Windows 32- and<br>64-bit; Linux 32-<br>and 64-bit |
| MATLAB<br>System object<br>and HDL<br>cosimulation        | MATLAB and<br>Fixed-Point<br>Toolbox                                | Communications<br>System Toolbox,<br>DSP System<br>Toolbox | Windows 32- and<br>64-bit; Linux 32-<br>and 64-bit |
| Simulink and<br>HDL simulator<br>cosimulation             | Simulink,<br>Simulink Fixed<br>Point, and<br>Fixed-Point<br>Toolbox | Signal<br>Processing<br>Toolbox, DSP<br>System Toolbox     | Windows 32- and<br>64-bit; Linux 32-<br>and 64-bit |

| Product          | Required                                                                          | Recommended                | Supported                                                |
|------------------|-----------------------------------------------------------------------------------|----------------------------|----------------------------------------------------------|
| Feature          | Products                                                                          | Products                   | Platforms                                                |
| FPGA-in-the-Loop | Simulink,<br>Simulink<br>Fixed Point,<br>Fixed-Point<br>Toolbox, and<br>HDL Coder | Filter Design<br>HDL Coder | Windows 32- and<br>64-bit; Linux 32-<br>and 64-bit       |
| FPGA             | MATLAB and                                                                        |                            | Windows 32- and                                          |
| Automation for   | Filter Design                                                                     |                            | 64-bit; Linux 32-                                        |
| Filter Design    | HDL Coder                                                                         |                            | and 64-bit                                               |
| TLM Generator    | Simulink Coder<br>and Embedded<br>Coder                                           |                            | Windows 32-bit<br>and 64-bit;<br>Linux 32- and<br>64-bit |

## **Optional Application Software**

To create the most robust development environment for your application consider adding the following MathWorks products to your HDL Verifier setup:

#### For HDL Cosimulation

- Communications System Toolbox
- DSP System Toolbox
- Signal Processing Toolbox
- Computer Vision System Toolbox

#### For Generating OSCI-Compatible TLM Components

- Simulink Fixed Point
- Embedded Coder

# Getting Help

- "Information Overview" on page 4-2
- "Online Help" on page 4-3
- "Using "What's This?" Context-Sensitive Help" on page 4-5
- "Demos and Tutorials" on page 4-7

# **Information Overview**

The following information is available with this product.

| Getting Started                           | Explains what HDL Verifier is, the<br>steps for installing and setting up<br>the product, how you might apply<br>the product to the hardware design<br>process, and how to gain access to<br>product documentation and online<br>help. Directs you to product demos<br>and tutorials. |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "HDL Verification with<br>Cosimulation"   | Explains what you need to know<br>to cosimulate with MATLAB<br>or Simulink, using either as a<br>component or a test bench, and your<br>HDL simulator.                                                                                                                                |
| "SystemC TLM 2.0 Generation"              | Provides instructions for creating a<br>SystemC Transaction Level Model<br>(TLM), which you can execute<br>in any OSCI-compatible TLM 2.0<br>environment, including a commercial<br>virtual platform.                                                                                 |
| "FPGA-in-the-Loop and FPGA<br>Automation" | Provides instruction for creating,<br>updating, and managing ISE<br>projects using HDL generated from<br>HDL Coder or Filter Design HDL<br>Coder software.                                                                                                                            |
| "Block Reference"                         | Provides descriptions and examples<br>of the blocks available for use in<br>Simulink.                                                                                                                                                                                                 |
| "Function Reference"                      | Provides descriptions and examples<br>of the functions available for use<br>with HDL Verifier software.                                                                                                                                                                               |
| "Demos and Tutorials" on page 4-7         | Provides examples of how you would use HDL Verifier software.                                                                                                                                                                                                                         |

# **Online Help**

| Online Help in the MATLAB Help<br>Browser | You can access online help by either of the following methods:                                                                                                                                                                                                                                                            |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                           | • Click the HDL Verifier product<br>link in the Help browser's<br>Contents pane.                                                                                                                                                                                                                                          |
|                                           | • Use the MATLAB doc command at the MATLAB command prompt:                                                                                                                                                                                                                                                                |
|                                           | >>doc edalink                                                                                                                                                                                                                                                                                                             |
| Help for HDL Verifier MATLAB<br>Functions | You can access function help by either of the following methods:                                                                                                                                                                                                                                                          |
|                                           | • By issuing the MATLAB help command. For example, enter the following command:                                                                                                                                                                                                                                           |
|                                           | >>help hdldaemon                                                                                                                                                                                                                                                                                                          |
|                                           | to get the MATLAB help for the hdldaemon function.                                                                                                                                                                                                                                                                        |
|                                           | • By clicking the 🏂 icon in the MATLAB command window.                                                                                                                                                                                                                                                                    |
| Context-sensitive "What's This?"<br>help  | For options that appear in the TLM<br>Generation and FPGA Automation<br>GUIs. Click a GUI Help button<br>or right-click on a GUI option<br>to display help on that dialog<br>or item. For more information<br>on using context-sensitive help<br>(CSH), see "Using "What's This?"<br>Context-Sensitive Help" on page 4-5. |
| Block Reference Pages                     | You can access block reference pages<br>through the Simulink interface. You<br>can also access these block reference                                                                                                                                                                                                      |

pages by clicking **Help** on any block dialog box.

# Using "What's This?" Context-Sensitive Help

"What's This?" context-sensitive help (CSH) topics are available for each option in the HDL Verifier GUIs. Use CSH to find more information when using the GUIs to configure options for TLM generation or FPGA project management.

To use CSH, follow these steps:

- 1 Place your cursor over the label or control for an option.
- **2** Right-click. A "What's This?" button appears. The following display shows the "What's This?" button appearing after a right-click on the **Workflow** option in the EDA Link pane.

| FPGA workflow options |                    |   |
|-----------------------|--------------------|---|
| Workflow:             | Project generation |   |
| Output-               | What's This?       | • |
| FPGA proje            | ect settings       |   |

**3** Left-click on "What's This?" to view the CSH that describes the option.

| 📣 Output                                                                                                                                    | x |
|---------------------------------------------------------------------------------------------------------------------------------------------|---|
| Output<br>Specify desired FPGA automation output                                                                                            |   |
| <mark>Settings</mark><br>Default: ISE project                                                                                               |   |
| ISE project<br>Creates an ISE project with generated HDL code for<br>the filter design, or add generated code to an existin<br>ISE project. | g |
| Tcl script<br>Generates a Tcl script for creating an ISE project or<br>for adding generated files to an existing ISE project.               | Е |
| <b>Dependencies</b><br>This parameter enables <b>Project type</b> when you set it to<br>ISE project.                                        |   |
| This parameter enables <b>Script type</b> when you set it to Tcl<br>script.                                                                 |   |
| See Also<br>FPGA Automation in MATLAB                                                                                                       | - |

# **Demos and Tutorials**

#### In this section...

"Demos" on page 4-7

"Tutorials" on page 4-7

# Demos

The demos give you a quick view of the product's capabilities and application examples that you can run with limited product exposure. You can find the HDL Verifier demos with the online documentation. To access demos, type at the MATLAB command prompt:

>> demos

Select HDL Verifier > Demos from the navigational pane.

# **Tutorials**

Tutorials provide procedural instruction on how to apply the product. Some focus on features while others focus on application scenarios. The tutorials listed here have a feature focus and address the use of the HDL Verifier software with HDL simulators and Simulink or MATLAB.

- "Verify Raised Cosine Filter Design With Generated MATLAB Component"
- "Verify Raised Cosine Filter Design With Generated Simulink Test Bench"
- "Verify HDL Model with MATLAB Testbench (Tutorial)"
- "Verify HDL Model with Simulink Test Bench (Tutorial)"
- "Visually Comparing Simulink Signals with HDL Signals (Tutorial)"

# HDL Code Importing

- "Generate HDL Cosimulation Interfaces from Existing HDL Code" on page 5-2
- "Import HDL Code For FPGA-in-the-Loop Verification" on page 5-24

# Generate HDL Cosimulation Interfaces from Existing HDL Code

#### In this section...

"Create a MATLAB Function From Existing HDL Code" on page 5-2 "Create a MATLAB System Object From Existing HDL Code" on page 5-9 "Create an HDL Cosimulation Block From Existing HDL Code" on page 5-10 "Perform Cosimulation" on page 5-21

# **Create a MATLAB Function From Existing HDL Code**

- "Invoke Cosimulation Wizard" on page 5-2
- "Select Cosimulation Type" on page 5-3
- "Select HDL Files to Import" on page 5-4
- "Specify HDL Compilation Commands" on page 5-5
- "Select HDL Modules for Cosimulation" on page 5-6
- "Specify Callback Schedule Parameters" on page 5-8
- "Generate Scripts" on page 5-9
- "Complete the Component or Test Bench Function" on page 5-9

## **Invoke Cosimulation Wizard**

- 1 Start MATLAB.
- 2 Enter the following command at the command prompt:
  - >> cosimWizard

The Cosimulation Wizard opens.

Continue with the next task: "Select Cosimulation Type" on page 5-3.

# Select Cosimulation Type

| 📣 Cosimulation Wizard                                         |                                                                                                                                                                                                      | ×      |
|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| Steps<br>-> Cosimulation Type<br>HDL Files<br>HDL Compilation | Actions<br>Select the type of cosimulation you want to do. If the HDL simulator execut<br>want to use is not on the system path in your environment, you must spec<br>location.                      |        |
| HDL Modules<br>Callback Schedule<br>Script Generation         | HDL cosimulation with: MATLAB  HDL Simulator: ModelSim Use HDL simulator executables on the system path Use the HDL simulator executables at the following location HDL simulator installation path: | Browse |
|                                                               | Status<br>Help Cancel                                                                                                                                                                                | Next > |

**1** Select **HDL cosimulation with** MATLAB to create a MATLAB function template.

#### 2 HDL Simulator

Select your HDL simulator. You may choose either Cadence Incisive or Mentor Graphics ModelSim.

**3** Specify where the Cosimulation Wizard can find your HDL simulator executables. You must enter a valid path to the HDL simulator executables before you can continue.

#### 4 Click Next.

## **Select HDL Files to Import**

| eps                                                     | Actions                                                                                                                                                                                                    |                              |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Cosimulation Type HDL Files HDL Compilation HDL Modules | Add all VHDL, Verilog, and/or script files to be used i<br>table. If the file type cannot be automatically detecte<br>incorrect, specify the correct file type in the table. The<br>order they are listed. | d or the detection result is |
| Callback Schedule<br>Script Generation                  | Add Remove Up Dow                                                                                                                                                                                          | /n                           |
|                                                         | HDL File                                                                                                                                                                                                   | File Type                    |
|                                                         | C:\Work\modsimrand.vhd                                                                                                                                                                                     | VHDL -                       |
|                                                         |                                                                                                                                                                                                            |                              |
|                                                         |                                                                                                                                                                                                            |                              |
|                                                         | Status                                                                                                                                                                                                     |                              |

- 1 Add files by clicking Add.
- **2** Remove files by first highlighting the file name in the **File List**, and then clicking **Remove**.
- **3** Move file positions in the list by selecting the file to move and clicking **Up** or **Down**.
- 4 Click Next.

| teps                                   | Actions                                                                                                                                                               |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cosimulation Type<br>HDL Files         | EDA Simulator Link has automatically generated the following HDL compilation<br>commands. You can customize these commands with optional parameters as specified      |
| > HDL Compilation                      | in the HDL simulator documentation but they are sufficient as shown to compile your<br>HDL code for cosimulation. The HDL files will be compiled when you click Next. |
| HDL Modules                            |                                                                                                                                                                       |
| Callback Schedule<br>Script Generation | Compilation Commands:                                                                                                                                                 |
|                                        | Vlib work<br>vcom -bindAtLoad "C:/Work/modsimrand.vhd"                                                                                                                |
|                                        | Restore Default Commands                                                                                                                                              |
|                                        | Status                                                                                                                                                                |

# **Specify HDL Compilation Commands**

- **1** Review the automatically generated HDL compilation commands. Enter any changes to the commands in the **Compilation Commands** box.
- **2** (Optional) Click **Restore Default Commands** to go back to the automatically generated HDL compilation commands at any time.
- 3 Click Next.

## **Select HDL Modules for Cosimulation**

The dialog box for **HDL Module Selection** varies depending on whether you have set **Cosimulation type** to ModelSim or Incisive<sup>®</sup>.

### HDL Module Selection for ModelSim

| 📣 Cosimulation Wizard                             |                                                                                                                                                            |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Steps                                             | Actions                                                                                                                                                    |
| Cosimulation Type<br>HDL Files<br>HDL Compilation | Specify the name of the HDL module for cosimulation. The Cosimulation Wizard will launch the HDL simulator and load the specified module in the next step. |
| -> HDL Modules                                    |                                                                                                                                                            |
| Callback Schedule<br>Script Generation            | Name of HDL module to cosimulate with: modsimrand -                                                                                                        |
|                                                   | Simulation options: -t 1ns -novopt                                                                                                                         |
|                                                   | Restore Defaults                                                                                                                                           |
|                                                   | Status                                                                                                                                                     |
|                                                   | Help Cancel < Back Next >                                                                                                                                  |

#### **HDL Module Selection for Incisive**

| Name of HDL module to cosimulate with: statecnt | •                |
|-------------------------------------------------|------------------|
| Elaboration options: -access +wc                |                  |
| Simulation options:                             |                  |
|                                                 | Restore Defaults |

- 1 Enter the name of the module where you see Name of HDL module to cosimulate with.
- 2 Provide any additional elaboration options in Elaboration options.
- **3** Specify additional simulation options where you see **Simulation options**. If you change your mind about the options you've added or changed, click **Restore Defaults**.
- 4 Click Next.

| Steps                                                            | Actions                                                                                                                                                                                                                                                                                   |
|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cosimulation Type<br>HDL Files<br>HDL Compilation<br>HDL Modules | Enter the required parameters for scheduling MATLAB callback function. When finished, use the 'Add' button to generate matlabtb or matlabcp commands that associates MATLAB function with an instantiated HDL design. If necessary, use the 'Remove' button to remove generated commands. |
| -> Callback Schedule                                             |                                                                                                                                                                                                                                                                                           |
| Script Generation                                                | Callback type: matlabcp  Callback function name: callback_fcn                                                                                                                                                                                                                             |
|                                                                  | HDL component: modsimrand Browse                                                                                                                                                                                                                                                          |
|                                                                  | Trigger mode: Repeat   Sample time (ns): 10                                                                                                                                                                                                                                               |
|                                                                  | Add Remove<br>MATLAB Callback Functions                                                                                                                                                                                                                                                   |
|                                                                  | matlabc modsimrand 10 ns -repeat 10 ns -mfunc callback fcn.m -use i                                                                                                                                                                                                                       |
|                                                                  | <                                                                                                                                                                                                                                                                                         |
|                                                                  |                                                                                                                                                                                                                                                                                           |
|                                                                  | Status                                                                                                                                                                                                                                                                                    |

- **1** Enter one or multiple component or test bench function callbacks from the HDL simulator.
- **2** When you finish specifying the callback function parameters, click **Add** to add the command to the MATLAB Callback Functions list.

If you have more callback functions you want to schedule, repeat the preceding steps. If you want to remove any callback functions, highlight the line for that function and click **Remove**.

3 Click Next.

# **Generate Scripts**

| 📣 Cosimulation Wizard                                            |                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Steps                                                            | Actions                                                                                                                                                                                                                                                                                                                     |
| Cosimulation Type<br>HDL Files<br>HDL Compilation<br>HDL Modules | <ul> <li>When you click Finish, the Cosimulation Wizard performs the following actions:</li> <li>Creates and opens a MATLAB script configured to launch the HDL simulator.</li> <li>Generates template(s) for the MATLAB callback function(s).</li> <li>(If you check the box below) Launches the HDL simulator.</li> </ul> |
| Callback Schedule -> Script Generation                           | After launching the HDL simulator, you might want observe the execution of the callback<br>functions by starting the simulation in the HDL simulator, for example, entering<br>command 'run 1000 ns'. Then you can modify the templates to implement the desired<br>algorithms in MATLAB.                                   |
|                                                                  | Launch HDL simulator after exiting this dialog.                                                                                                                                                                                                                                                                             |
|                                                                  | Status                                                                                                                                                                                                                                                                                                                      |
|                                                                  | Help Cancel < Back Finish                                                                                                                                                                                                                                                                                                   |

- Click **Back** to review or change your settings.
- Click **Finish** to generate the scripts.

## **Complete the Component or Test Bench Function**

Complete the template using the MATLAB Editor. The generated template contains some simple port I/O instructions and empty routines where you add your own code.

# Create a MATLAB System Object From Existing HDL Code

For a guided tutorial on how to use the Cosim Wizard to create a MATLAB System object for HDL Cosimulation, see Cosimulation Wizard for MATLAB System Object (IN) or Cosimulation Wizard for MATLAB System Object (MQ). You can also find out more in the user guide section "HDL Cosimulation Using MATLAB System Object".

# Create an HDL Cosimulation Block From Existing HDL Code

- "Invoke Cosimulation Wizard" on page 5-10
- "Select Cosimulation Type" on page 5-11
- "Select HDL Files to Import" on page 5-12
- "Specify HDL Compilation Commands" on page 5-13
- "Select HDL Modules for Cosimulation" on page 5-14
- "Configure Simulink Ports" on page 5-16
- "Specify Output Port Details" on page 5-17
- "Specify Clock and Reset Details" on page 5-18
- "Confirm or Change Start Time Alignment" on page 5-19
- "Generate Block" on page 5-20
- "Complete the Simulink Model" on page 5-20

# **Invoke Cosimulation Wizard**

- 1 Start MATLAB.
- 2 Enter the following command at the command prompt:
  - >> cosimWizard

The Cosimulation Wizard opens.

# Select Cosimulation Type

| 🙀 Cosimulation Wizard                                                                                                   |                                                                                                                                                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Steps -> Cosimulation Type HDL Files HDL Compilation                                                                    | Actions<br>Select the type of cosimulation you want to do. If the HDL simulator executable you<br>want to use is not on the system path in your environment, you must specify its<br>location.                                                |
| HDL Modules<br>Simulink Ports<br>Output Port Details<br>Clock/Reset Details<br>Start Time Alignment<br>Block Generation | HDL cosimulation with: Simulink ▼ HDL Simulator: ModelSim ▼ <ul> <li>Use HDL simulator executables on the system path</li> <li>Use the HDL simulator executables at the following location</li> </ul> HDL simulator installation path: Browse |
|                                                                                                                         | Status<br>Help Cancel Next >                                                                                                                                                                                                                  |

**1** Select **HDL cosimulation with** Simulink to create an HDL Cosimulation block using the HDL code you provide to define the ports, clocks, and resets.

#### 2 HDL Simulator

Select your HDL simulator. You may choose either Cadence Incisive or Mentor Graphics ModelSim.

**3** Specify where the Cosimulation Wizard can find your HDL simulator executables. You must enter a valid path to the HDL simulator executables before you can continue.

#### 4 Click Next.

## **Select HDL Files to Import**

| teps                                                                                                                              | Actions                                                                                                                                                                                             |                                 |
|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Cosimulation Type<br>HDL Files<br>HDL Compilation<br>HDL Modules<br>Simulink Ports<br>Output Port Details<br>Cleable Cost Details | Add all VHDL, Verilog, and/or script files to be used<br>table. If the file type cannot be automatically detect<br>incorrect, specify the correct file type in the table.<br>order they are listed. | cted or the detection result is |
| Clock/Reset Details<br>Start Time Alignmen                                                                                        | + HDL File                                                                                                                                                                                          | File Type                       |
| Block Generation                                                                                                                  | C:\Work\decoder.v                                                                                                                                                                                   | Verilog 🔻                       |
| block deneration                                                                                                                  | C:\Work\statecnt.v                                                                                                                                                                                  | Verilog 🔻                       |
|                                                                                                                                   | C:\Work\iqconv.v                                                                                                                                                                                    | Verilog 🔻                       |
|                                                                                                                                   |                                                                                                                                                                                                     |                                 |
|                                                                                                                                   | Status                                                                                                                                                                                              |                                 |

- 1 Add files by clicking Add.
- **2** Remove files by first highlighting the file name in the **File List**, and then clicking **Remove**.
- **3** Move file positions in the list by selecting the file to move and clicking **Up** or **Down**.
- 4 Click Next.

| eps                                                                                    | Actions                                                                                                                                                                                                                                                 |
|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cosimulation Type<br>HDL Files                                                         | EDA Simulator Link has automatically generated the following HDL compilation<br>commands. You can customize these commands with optional parameters as specified<br>in the HDL simulator documentation but they are sufficient as shown to compile your |
| <ul> <li>HDL Compilation</li> <li>HDL Modules</li> </ul>                               | HDL code for cosimulation. The HDL files will be compiled when you click Next.                                                                                                                                                                          |
| Simulink Ports                                                                         | Compilation Commands:                                                                                                                                                                                                                                   |
| Output Port Details<br>Clock/Reset Details<br>Start Time Alignment<br>Block Generation | vlib work<br>vlog -incr "C:/Work/decoder.v"<br>vlog -incr "C:/Work/statecnt.v"<br>vlog -incr "C:/Work/iqconv.v"                                                                                                                                         |
|                                                                                        | Restore Default Commands                                                                                                                                                                                                                                |
|                                                                                        | Status                                                                                                                                                                                                                                                  |

# **Specify HDL Compilation Commands**

- **1** Review the automatically generated HDL compilation commands. Enter any changes to the commands in the **Compilation Commands** box.
- **2** (Optional) Click **Restore Default Commands** to go back to the automatically generated HDL compilation commands at any time.
- 3 Click Next.

## **Select HDL Modules for Cosimulation**

The dialog box for **HDL Module Selection** varies depending on whether you have set **Cosimulation type** to ModelSim or Incisive.

### HDL Module Selection for ModelSim

| 🙀 Cosimulation Wizard                                                          |                                                                                                                                                                                                                  | x   |
|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Steps                                                                          | Actions                                                                                                                                                                                                          |     |
| Cosimulation Type<br>HDL Files<br>HDL Compilation                              | Specify the name of the HDL module for cosimulation. The Cosimulation Wizard will<br>launch the HDL simulator, load the specified module, and populate the port list of that<br>HDL module before the next step. |     |
| -> HDL Modules<br>Simulink Ports<br>Output Port Details<br>Clock/Reset Details | Name of HDL module to cosimulate with: statecnt                                                                                                                                                                  | •   |
| Start Time Alignment<br>Block Generation                                       | Simulation options: -t 1ns -novopt                                                                                                                                                                               |     |
|                                                                                | Restore Defau                                                                                                                                                                                                    | lts |
|                                                                                | Status                                                                                                                                                                                                           |     |
|                                                                                | Help         Cancel          Next >                                                                                                                                                                              |     |

#### **HDL Module Selection for Incisive**

| Name of HDL module to cosimulate with: statecnt | •                |
|-------------------------------------------------|------------------|
| Elaboration options: -access +wc                |                  |
| Simulation options:                             |                  |
|                                                 | Restore Defaults |

- 1 Enter the name of the module where you see Name of HDL module to cosimulate with.
- 2 Provide any additional elaboration options in Elaboration options.
- **3** Specify additional simulation options where you see **Simulation options**. If you change your mind about the options you've added or changed, click **Restore Defaults**.
- 4 Click Next.

# **Configure Simulink Ports**

| ps                                                               | Actions                   |                                                         |                                                                                                       |                      |
|------------------------------------------------------------------|---------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------|
| Cosimulation Type<br>HDL Files<br>HDL Compilation<br>HDL Modules | will be forced in the HDL | simulator through Tcl co<br>eset' signals in the next s | nals that are identified as 'C<br>ommands. You can specify t<br>step. If you want to drive yo<br>ut'. | he timing parameters |
| Simulink Ports                                                   | Input Port List           |                                                         | Output Port List                                                                                      |                      |
| Output Port Details<br>Clock/Reset Details                       | Port Name                 | Port Type                                               | Port Name                                                                                             | Port Typ             |
| Start Time Alignment                                             | clk                       | Clock -                                                 | sync                                                                                                  | Output               |
| Block Generation                                                 | enable                    | Input 🔻                                                 | i_wf                                                                                                  | Output               |
|                                                                  | reset                     | Reset 🔻                                                 | q_wf                                                                                                  | Output               |
|                                                                  |                           |                                                         |                                                                                                       |                      |
|                                                                  |                           |                                                         |                                                                                                       |                      |
|                                                                  | Status                    |                                                         |                                                                                                       |                      |

- **1** For **Port Type**, confirm the auto-selected types or specify one of the following:
  - Input
  - Clock
  - Reset
  - Unused
- 2 Click Next.

| Specify | Output | Port | Details |
|---------|--------|------|---------|
|---------|--------|------|---------|

|                                                                  | Actions                          |                     |                                         |                                                                                 |              |
|------------------------------------------------------------------|----------------------------------|---------------------|-----------------------------------------|---------------------------------------------------------------------------------|--------------|
| Cosimulation Type<br>HDL Files<br>HDL Compilation<br>HDL Modules | time as -1, wh<br>model. Back pr | ich means that it v | vill be inherited<br>I in certain circu | ut port. You can specify<br>via back propagation in<br>ımstances; click Help fo | the Simulink |
| Simulink Ports -> Output Port Details                            | Output Port                      |                     |                                         |                                                                                 |              |
| Clock/Reset Details<br>Start Time Alignment                      | Port Name                        | Sample Time         | Data Type                               | Fraction Length                                                                 |              |
| Block Generation                                                 | sync                             | 1                   | Inherit 💌                               | Inherit                                                                         |              |
|                                                                  | i_wf                             | 1                   | Inherit 🔻                               | Inherit                                                                         | ]            |
|                                                                  | q_wf                             | 1                   | Inherit 🔻                               | Inherit                                                                         |              |
|                                                                  |                                  |                     |                                         |                                                                                 |              |
|                                                                  | Status                           |                     |                                         |                                                                                 |              |

- Verify that the default sample time and the default data type what you expect them to be. These settings are consistent with the way the HDL Cosimulation block mask (Ports tab) sets default settings for output ports. Do not change these values unless you are certain you do not want the default values.
- 2 Click Next.

| 🙀 Cosimulation Wizard                             | ×                                                                                                                  |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Steps                                             | Actions                                                                                                            |
| Cosimulation Type<br>HDL Files<br>HDL Compilation | Set clock and reset parameters here. The time in these tables refers to time in the HDL simulator.                 |
| HDL Modules<br>Simulink Ports                     | HDL time unit ns •                                                                                                 |
| Output Port Details                               | Clocks                                                                                                             |
| -> Clock/Reset Details                            | Clock Name Period(ns) Active Edge                                                                                  |
| Start Time Alignment<br>Block Generation          | Clk     10 Rising       Resets       Reset Name       Initial Value       Duration(ns)       reset       1       8 |
|                                                   | Status<br>Help Cancel < Back Next >                                                                                |

1 Verify that the default clock settings and the default reset settings are as you expected. Do not change these settings unless you are certain you do not want the default values.

The next screen provides a visual display of the simulation start time where you can review how the clocks and resets line up.

2 Click Next.



# **Confirm or Change Start Time Alignment**

1 Verify that the rising or falling edge is set where you want it (from the previous step) by looking at the start time and the reset signal.

- 2 Make sure that the start time is where you want it.
- 3 Click Next.

## **Generate Block**

| 🙀 Cosimulation Wizard                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Steps                                                                                                                                                                           | Actions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Cosimulation Type<br>HDL Files<br>HDL Compilation<br>HDL Modules<br>Simulink Ports<br>Output Port Details<br>Clock/Reset Details<br>Start Time Alignment<br>-> Block Generation | <ul> <li>When you click Finish, the Cosimulation Wizard performs the following actions:         <ul> <li>Creates and opens a new Simulink model containing an HDL Cosimulation block configured to your specifications.</li> <li>Generates the scripts to compile your HDL code and launch the HDL simulator accord to the choices you made with this assistant.</li> <li>(If you check the box below) Configures the HDL Cosimulation block to assist you in setting the simulation timescale when you cosimulate with the generated block for the time. If you do not check the box below, the timescale is set to the default of 1 Simulin second = 1 second in the HDL simulator, or you may change it below.</li> </ul> </li> </ul> |  |
|                                                                                                                                                                                 | Status Help Cancel < Back Finish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |

Indicate whether you want HDL Verifier software to automatically determine the timescale when you start the simulation or if you'd prefer to determine the timescale yourself. The default is to automatically determine timescale.

- Click **Back** to review or change your settings.
- Click Finish to generate the HDL Cosimulation block.

#### **Complete the Simulink Model**

Insert the generated HDL Cosimulation block into your existing model.



Make any desired changes or updates to your Simulink model before you begin cosimulation.

# **Perform Cosimulation**

After you finish creating a function or block, select the topic that describes how you are planning to cosimulate your HDL code.

If you generated a component (matlabcp) or test bench (matlabtb) function for cosimulation with MATLAB, select one of the following topics:

**MATLAB** Cosimulation

| Task to Perform                                    | Read                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Simulate an HDL component with a MATLAB test bench | <ul> <li>Because you already have a completed test bench function written, you can pick up at this step: "Place Test Bench Function on MATLAB Search Path". If you need help finishing the function, see "Create an HDL Verifier MATLAB Component Function".</li> <li>For the full process and description, see "HDL</li> </ul> |

| Task to Perform                                 | Read                                                                                                                                                                                              |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                 | Cosimulation Using MATLAB<br>Test Bench Function".                                                                                                                                                |
| Replace HDL component with a<br>MATLAB function | • Because you already have a completed component function written, you can pick up at this step: "Place Component Function on MATLAB Search Path". If you need help finishing the function, see . |
|                                                 | • For the full process and<br>description, see "HDL<br>Cosimulation Using MATLAB<br>Component Function".                                                                                          |

#### **MATLAB** Cosimulation (Continued)

If you generate an HDL Cosimulation block for cosimulation with Simulink, select one of the following topics:

### **Simulink Cosimulation**

| Task to Perform                                    | Read                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Simulate HDL component with<br>Simulink test bench | <ul> <li>Because you already have the HDL design and a Simulink test bench model with the customized HDL Cosimulation block, and the HDL simulator is running, you can pick up at this step: "Run a Test Bench Cosimulation Session". First, however, review the entire "Simulating an HDL Component in a Simulink Test Bench".</li> <li>For the full process and description, see</li> </ul> |

| Task to Perform            | Read                                                                                                                                                                                                                                                                                                     |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Replace HDL component with | <ul><li>"Simulating an HDL Component<br/>in a Simulink Test Bench<br/>Environment".</li><li>Because you already have the</li></ul>                                                                                                                                                                       |
| Simulink algorithm         | HDL design and a Simulink<br>component model with the<br>customized HDL Cosimulation<br>block, and the HDL simulator<br>is running, you can pick up at<br>this step: "Run a Component<br>Cosimulation Session". First,<br>however, review the entire "Using<br>Simulink to Replace an HDL<br>Component". |
|                            | • For the full process and description, see "Replacing an HDL Component with a Simulink Algorithm".                                                                                                                                                                                                      |

#### Simulink Cosimulation (Continued)

For additional help on HDL Verifier topics, see the "Information Overview" on page 4-2.

# Import HDL Code For FPGA-in-the-Loop Verification

#### In this section ...

"Preparing to Use the FPGA-in-the-Loop (FIL) Wizard" on page 5-24

"Running the FIL Wizard" on page 5-24

"Performing FIL Simulation" on page 5-29

# Preparing to Use the FPGA-in-the-Loop (FIL) Wizard

Before beginning:

- 1 Have your HDL code ready and the original model opened.
- **2** Set up your project tools by specifying the path to the executables. See "Generate FIL Block" in the User Guide.

For more detailed information, see "FPGA-in-the-Loop (FIL)". For a demonstration of FIL, see the FPGA-in-the-Loop demos under HDL Verifier.

#### Altera Board with Linux

If you are using the Altera board and a Linux distribution supported by Altera, you should first read the "USB-Blaster Download Cable User Guide" provided on the Altera web site: http://www.altera.com/literature/ug/ug\_usb\_blstr.pdf. Specifically, to program the bit file you must be a superuser. The user guide provides instructions for making a one-time modification to a rules file to give you that permission.

# **Running the FIL Wizard**

1 At the MATLAB prompt, enter the following:

>> filWizard

2 Select the FPGA vendor you are using (FPGA design software) to display boards supported for that vendor. Choose either Altera or Xilinx. If you leave the selection at All, all supported boards will be displayed in the pull-down menu.

**3** Select the board you are using. Adjust the Board IP address if applicable. Click **Next** to continue.

| FPGA-in-the-Loop W<br>Steps         | Actions                                         |
|-------------------------------------|-------------------------------------------------|
|                                     |                                                 |
| -> Hardware Options<br>Source Files |                                                 |
| DUT I/O Ports                       | FPGA Vendor: All                                |
| Build Options                       | Board: Xilinx Spartan-6 SP601 development board |
|                                     |                                                 |
|                                     | FPGA device: Spartan6 XC6SLX16-2-CSG324         |
|                                     | FPGA-in-the-Loop communication: Ethernet        |
|                                     |                                                 |
|                                     |                                                 |
|                                     | Advanced Options                                |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     | Status                                          |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     |                                                 |
|                                     | Help Cancel Next >                              |

**4** Select your HDL source files. Indicate the top-level module. Click **Next** to continue.

| 🙀 FPGA-in-the-Loop Wiza                                      | rd                                                                                                                                                             |                                                      |                   | <b>X</b>                        |
|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------|---------------------------------|
| Steps                                                        | Actions                                                                                                                                                        |                                                      |                   |                                 |
| Hardware Options -> Source Files DUT I/O Ports Build Options | Specify the source files for the H<br>the file type in the File Type colu<br>Enter a check next to the file nar<br>incorrect in the Top-level module<br>order. | mn if it is incorrect.<br>ne that contains the top-l | level module. Chi | ange the module name if it is   |
|                                                              | Source Files:                                                                                                                                                  |                                                      | <b></b>           | Show full paths to source files |
|                                                              | File                                                                                                                                                           | File Type                                            | Top-level         | Add                             |
|                                                              | UnitDelay.vhd                                                                                                                                                  | VHDL -                                               | 7                 | Remove                          |
|                                                              |                                                                                                                                                                |                                                      |                   | Up                              |
|                                                              |                                                                                                                                                                |                                                      |                   | Down                            |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              | Top-level module name: UnitDel                                                                                                                                 | ау                                                   |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              | Status                                                                                                                                                         |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              |                                                                                                                                                                |                                                      |                   |                                 |
|                                                              | Help Cancel                                                                                                                                                    |                                                      |                   | < Back Next >                   |

**5** Review the DUT I/O ports. Change any settings if desired. Click **Next** to continue.

| Hardware Options<br>Source Files       Specify port type for all I/O ports in the top-level DUT. If necessary, add, remove, or information such as name, direction, and width.         DUT I/O Ports <ul> <li>Automatically generate I/O port name, direction and width from top-level module</li> <li>Manually enter I/O port information</li> </ul> DUT I/O Ports <ul> <li>Manually enter I/O port name, direction and width from top-level module</li> <li>Manually enter I/O port information</li> </ul> DUT I/O Ports: <ul> <li>Port Name</li> <li>Clk</li> <li>In</li> <li>In</li> <li>Iclock</li> <li>reset</li> <li>In</li> <li>I</li></ul> | nodify other pr |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Build Options <ul> <li>Automatically generate I/O port name, direction and width from top-level module</li> <li>Manually enter I/O port information</li> </ul> DUT I/O Ports:         Port Name       Port Direction         Direction       Width         clk       In •         clk_enable       In •         in1       In •         in2       In •         in3       In •         in4       In •         in5       In •         ce_out       Out •         out1       Out •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | nouny onler po  |
| Port NamePort Direction<br>Direction<br>WidthPort TypeclkInInClockresetInInResetclk_enableInInClock enablein1InInDatain2InS Datain3In9 Datain4In3 Datain5In8 Datace_outOut1 Dataout1Out1 Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |
| Port Name     Direction     Width     Port Type       clk     In     In     1     Clock       reset     In     I     Reset       clk_enable     In     I     Clock enable       in1     In     I     Data       in2     In     5     Data       in3     In     9     Data       in4     In     3     Data       ce_out     Out     1     Data       out1     Out     1     Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |
| reset In • 1 Reset<br>clk_enable In • 1 Clock enable<br>in1 In • 1 Data<br>in2 In • 5 Data<br>in3 In • 9 Data<br>in4 In • 3 Data<br>in5 In • 8 Data<br>ce_out Out • 1 Data<br>out1 • Out • 1 Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Re-gener        |
| clk_enable       In       In       I       Clock enable         in1       In       In       I       Data         in2       In       S       Data         in3       In       9       Data         in4       In       3       Data         in5       In       8       Data         out1       Out       1       Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |
| in1     In     ▼     1     Data       in2     In     ▼     5     Data       in3     In     ▼     9     Data       in4     In     ▼     3     Data       in5     In     ▼     8     Data       out1     Out     ▼     1     Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |
| in2 In ▼ 5 Data<br>in3 In ▼ 9 Data<br>in4 In ▼ 3 Data<br>in5 In ▼ 8 Data<br>ce_out Out ▼ 1 Data<br>out1 Out ▼ 1 Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | E               |
| in3 In ▼ 9 Data<br>in4 In ▼ 3 Data<br>in5 In ▼ 8 Data<br>ce_out Out ▼ 1 Data<br>out1 Out ▼ 1 Data<br>✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| in4 In ▼ 3 Data<br>in5 In ▼ 8 Data<br>ce_out Out ▼ 1 Data<br>out1 Out ▼ 1 Data<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |
| in5 In ▼ 8 Data<br>ce_out Out ▼ 1 Data<br>out1 Out ▼ 1 Data<br>∢ III ▼ 1 Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |
| ce_out     Out     ▼     1     Data       out1     Out     ▼     1     Data        III     III     III                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| out1 Out • 1Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Ŧ               |
| Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | •               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |

There must be at least one input and one output data port.

**6** Select the output folder for the programming files. Click **Next** to continue.

| 🙀 FPGA-in-the-Loop Wiz                                                | ard                                                                                                                                                                                                                                                                                                                                                                                                      | <b>×</b>     |
|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| Steps                                                                 | Actions                                                                                                                                                                                                                                                                                                                                                                                                  |              |
| Hardware Options                                                      | Specify folder for output files and begin build process.                                                                                                                                                                                                                                                                                                                                                 |              |
| Hardware Options<br>Source Files<br>DUT I/O Ports<br>-> Build Options | Specify folder for output files and begin build process. Output folder: .\Unitdelay_fil Summary User top-level source file: C:\Work\UnitDelay.vhd The following files are generated at the end of this build process: FPGA project file: .\Unitdelay_fil\fpgaproj\Unitdelay_fil.xise FPGA programming file: .\Unitdelay_fil\Unitdelay_fil.bit The FIL simulation block will be generated in a new model. | Browse       |
|                                                                       | Status<br>Help Cancel                                                                                                                                                                                                                                                                                                                                                                                    | < Back Build |

#### 7 Click Build.

During the build process, the following actions occur:

• The FIL Wizard generates a FIL block named after the top-level module and places it in a new model.



- After new model generation, the FIL Wizard opens a command window.
  - In this window, the FPGA design software performs synthesis, fit, place-and-route, timing analysis, and FPGA programming file generation.
  - When the process is finished, a message in the command window lets you know you can close the window.

For more detailed information about the FIL Wizard, see "Generating a FIL Block Using the FIL Wizard". For more information about the FIL process, see "FPGA-in-the-Loop (FIL)". For a demonstration of FIL, see the FPGA-in-the-Loop demos under HDL Verifier.

# **Performing FIL Simulation**

- 1 Insert the generated FIL block into the existing model.
- 2 Open the block mask and load the programming files.

| -PGA-in-the-Loop (FIL)               |                                             |
|--------------------------------------|---------------------------------------------|
| Execute hardware component on FPG.   | A development board.                        |
| Main Signal Attributes               |                                             |
| - grid f the ballo                   |                                             |
| Hardware Information                 |                                             |
| MAC address:                         | 00-0A-35-02-21-8A                           |
| IP address:                          | 192.168.0.2                                 |
| Board:                               | Xilinx Spartan-6 SP605 development board    |
|                                      | Spartan6 XC6SLX45T-3-FGG484                 |
| FPGA project file:                   | Controller_fil\fpgaproj\Controller_fil.xise |
|                                      |                                             |
| FPGA Programming File                |                                             |
| File name: C:\Users\fil_tests\Contr  | oller fil\Controller fil.bit Browse Load    |
|                                      |                                             |
| Status: FPGA programming file not lo | baded                                       |
| Runtime Options                      |                                             |
| Overclocking factor:                 | 1 -                                         |
|                                      |                                             |
|                                      |                                             |
| Output frame size:                   | Inherit: auto 👻                             |
|                                      | Inherit: auto                               |

#### Altera Board with Linux

If you are using the Altera board and a Linux distribution supported by Altera, you should first read the "USB-Blaster Download Cable User Guide" provided on the Altera web site: http://www.altera.com/literature/ug/ug\_usb\_blstr.pdf. Specifically, to program the bit file you must be a superuser. The user guide provides instructions for making a one-time modification to a rules file to give you that permission.

3 Make any other adjustments on the block mask, if desired.

|         | Signal Att |        |              | A development board.               |   |               |  |
|---------|------------|--------|--------------|------------------------------------|---|---------------|--|
| HDL     | Name       | Dir    | Bit<br>Width | Sample<br>Time                     |   | Data type     |  |
| error_d | ı          | Input  | 32           | Inherit: Inherit via propagation   | - | Inherit: auto |  |
| ontrol  | _signal    | Output | 32           | Inherit: Inherit via internal rule | • | ufix32        |  |
|         |            |        |              |                                    |   |               |  |

**4** Run the FIL simulation.

For more detailed information, see "FPGA-in-the-Loop (FIL)". For a demonstration of FIL, see the FPGA-in-the-Loop demos under HDL Verifier.

# Index

# A

application software 3-4
application specific integrated circuits (ASICs) 1-1
ASICs (application specific integrated circuits) 1-1

# B

blocksets installing 2-3

# C

client for MATLAB and HDL simulator links 1-3 for Simulink and HDL simulator links 1-3 client/server environment MATLAB and HDL simulator 1-3 Simulink and HDL simulator 1-3 communication modes of 1-8 Communications System Toolbox<sup>™</sup> as optional software 3-4 cosimulation environment MATLAB and HDL simulator 1-3 Simulink and HDL simulator 1-3

# D

demos 4-7 for HDL Verifier<sup>™</sup> 4-1 for use with FPGA implementations 4-1 documentation overview 4-1 for use with FPGA implementations 4-1 DSP System Toolbox<sup>™</sup> as optional software 3-4

# E

EDA (Electronic Design Automation) 1-1 Electronic Design Automation (EDA) 1-1 environment cosimulation with MATLAB and HDL simulator 1-3 cosimulation with Simulink and HDL simulator 1-3

## F

field programmable gate arrays (FPGAs) 1-1 FPGAs (field programmable gate arrays) 1-1

## Η

hardware description language (HDL). See HDL HDL (hardware description language) 1-1 HDL Cosimulation block in HDL Verifier<sup>™</sup> environment 1-3 HDL simulators in HDL Verifier<sup>™</sup> environment 1-3 installing 2-3 working with Simulink links to 1-3 HDL Verifier<sup>™</sup> software definition of 1-1 installing 2-2 help for HDL Verifier<sup>™</sup> software 4-1 for use with FPGA implementations 4-1

# 

Incisive in HDL Verifier<sup>™</sup> cosimulation environment 1-3 working with MATLAB links to 1-3 Incisive or NC simulators as required software 3-4 installation of HDL Verifier  $^{\rm TM}$  software 2-2 of related software 2-3

# L

links MATLAB and HDL simulator 1-3 Simulink and HDL simulator 1-3

# Μ

MATLAB as required software 3-4 in HDL Verifier<sup>™</sup> cosimulation environment 1-3 installing 2-3 working with HDL simulator links to 1-3 MATLAB functions test bench 1-3 MATLAB server function for invoking 1-3 ModelSim in HDL Verifier<sup>™</sup> cosimulation environment 1-3 working with MATLAB links to 1-3 ModelSim simulators as required software 3-4

# 0

online help where to find it 4-1 for use with FPGA implementations 4-1 OS platform. See HDL Verifier<sup>™</sup> product requirements page on the MathWorks Web site

#### Ρ

platform support required 3-4 prerequisites for using HDL Verifier<sup>™</sup> software 3-1

## R

requirements application software 3-4 checking product 3-4 platform 3-4

## S

server, MATLAB for MATLAB and HDL simulator links 1-3 for Simulink and HDL simulator links 1-3 shared memory communication 1-8 Simulink as optional software 3-4 in HDL Verifier<sup>™</sup> environment 1-3 installing 2-3 working with HDL simulator links to 1-3 Simulink Fixed Point as optional software 3-4 sockets 1-8 See also TCP/IP socket communication software installing HDL Verifier<sup>™</sup> 2-2 installing related application software 2-3 optional 3-4 required 3-4

# T

TCP/IP networking protocol 1-8 See also TCP/IP socket communication
TCP/IP socket communication mode 1-8
To VCD File block uses of 1-3
tutorials 4-7 for HDL Verifier<sup>™</sup> 4-1 for use with FPGA implementations 4-1

# U

users

#### for HDL Verifier<sup>™</sup> software 3-1